草庐IT

mysql - 在sql中对一行求和

全部标签

ruby - 如何转义 Ruby 中的字符串以防止 SQL 注入(inject)? (无导轨)

我只是想知道我们如何在Ruby中转义SQL查询(字符串)以防止SQL注入(inject)。请注意我没有使用Rails框架。谢谢。 最佳答案 如果可能,请使用RubyDBI模块,而不是尝试引用您的字符串,而是使用参数化的准备查询,如下所示:dbh=DBI.connect("DBI:Mysql:test:localhost","testuser","testpass")sth=dbh.prepare("INSERTINTOpeople(id,name,height)VALUES(?,?,?)")File.open("people.txt

sql - 如何使用 Sequel 运行原始 SQL 查询

我还不清楚使用Sequel运行原始SQL查询的正确方法。目前我正在尝试这个:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")do|row|@zonename=rowend我怎样才能将查询作为原始SQL运行,然后像平常一样访问结果?if@zonename.name="UK" 最佳答案 请注意,而不是:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")你应该这样做:DB.fetch("SELE

ruby - 你能在 Ruby 中的一行中创建/写入/附加一个字符串到文件吗

这有可能吗?v='sometext'w='my'+Time.new.strftime("%m-%d-%Y").to_s+'.txt'File.write(w,v)#willcreatefileifitdoesn'texistandrecreateseverytime无需在实例上执行File.open?即只是一个将追加或创建和写入的类方法?理想情况下是ruby​​1.9.3soln。谢谢编辑1这是我根据文档尝试的方法。我没有看到rdoc,但看到了一些其他示例。我再次询问是否可以通过File.write以追加模式打开文件?谢谢irb(main):014:0>File.write('some

ruby-on-rails - 在 Rails 中对暂存/生产环境进行冒烟测试的最佳方法是什么?

首先,设置...我目前正在使用Ruby1.8.7MRI在MacOSX上开发Rails3应用程序,针对MySQL数据库运行测试和本地开发。我有3个“其他”非本地环境,我们在公司使用这些环境来处理名为dev、tqa和prod的每个应用程序。它们使用JRuby(1.8.7)在Tomcat中运行,以Oracle作为后端。如您所见,环境大不相同,我们在部署到本地不存在的Oracle/JRuby环境时遇到了一些错误(例如日期处理和指定Oracle中的默认模式)。我喜欢在本地运行Cucumber/Webrat/Capybara之类的东西来访问应用程序中公开的每个URL,以确保基本功能正常运行(即冒烟

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for

ruby-on-rails - 在 RoR 中对 UTF-8 字符串进行排序

我正试图找出一种在RubyonRails中对UTF-8字符串进行排序的“正确”方法。在我的应用程序中,我有一个填充了国家/地区的选择框。由于我的应用程序已本地化,每个现有的语言环境都有一个countries.yml文件,该文件将国家的ID与该国家/地区的本地化名称相关联。我无法在yml文件中手动对字符串进行排序,因为我需要ID在所有语言环境中保持一致。我所做的是创建一个使用unidecode的ascii_name方法gem将重音字符和非拉丁字符转换为对应的ascii字符(例如,“Afeganistão”将变为“Afeganistao”),然后对其进行排序:require'unideco

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby-on-rails - Rails Unicorn - 启动请求和到达 Controller 之间的延迟

我正在使用Unicorn作为我的Rails应用程序的应用程序服务器,并且我试图弄清楚为什么有时在请求开始和请求到达我的Controller之间会有一个重要的(>5秒)延迟.这是我的production.log打印出来的:StartedGET"/search/articles.json?q=mashable.com"for138.7.7.33at2015-07-2314:59:19-0400**Parameters:{"q"=>"mashable.com"}Searchingarticlesforkeyword:mashable.com,format:json,Time:2015-07-

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d